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METHOD, SYSTEM, APPARATUS AND 
PROGRAM PRODUCT FOR DISTRIBUTION AND 
INSTANTIATION OF SOFTWARE UPGRADES 

CROSS-REFERENCE TO RELATED APPLICATIONS 

5 This application claims priority under 35 USC §120 and/or §365 to PCT International 
Application Serial No. PCT/US99/04581 filed March 3, 1999, which, in turn Haf™ 
priority to U.S. Provisional Application No. 60/076,667 filed March 3, 1998, each of 
which is incorporated herein in its entirety by reference. 

FIELD OF THE INVENTION 

10 This invention relates to a system, method, and program product for providing 
software updates online. The updates may be provided to one or more of a sequence 
of individual computers, or to a network of computers. In a preferred exemplification, 
the software updates are provided to individual clients in a client server-network, for 
example a client-server network of the type executing a partially replicated relational 

15 database or transaction processing system, an enterprise on a WAN or a LAN. 

BACKGROUND OF THE INVENTION 

Business enterprises utilize large numbers of terminals, Le., desktop computers, 
portable computers, and network terminals to carry out their activities. While it is 
desirable that all of these terminals have identical images, interfaces, and software, 
20 this is not always possible when a continuum of terminal ages and capabilities exists 
in an enterprise. However, it is absolutely essential that the set of terminals in an 
enterprise be able to communicate effectively. This requires careful pl annin g for and 
coordination of software migration efforts. 

In a system including one or more central databases (including correspondence 
25 databases and such databases as are contemplated in groupware applications such as 
Lotus Notes. Novell Group Wise, and the like) and locally partially replicated 
databases, there is considerable amount of software which is often customized to meet 
the needs of particular enterprise, and even particular users and groups of users within 
elements of the enterprise. A great deal of effort is expended on configuring the 
30 software and writing custom modules and objects. If the software is upgraded to a 
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new release, a considerable amount of programming time and effort are required to 
provide consistent upgrades while configuring the new release and rdmplementing 
the customer-specific functionality of the earlier versions. 

It is therefore desirable to provide a capability to provide a facility which allows 
5 enterprises to rapidly migrate their changes from one version of the software to 
another version of the software, such as configurations and objects. 

It would be desirable to accomplish rapid migration of software upgrades in a user- 
friendly, on-line method through the use of on-line distribution of software upgrades. 

OBJECTS OF THE INVENTION 

10 It is an object of the invention to provide on-line distribution of software upgrades 
while satisfying the following business requirements: 

It is a primary object of our invention to provide database schema synchroTuzatiorx 

It is a further object of our invention to provide support for all types of installations 
and terminals in an enterprise. That is, the soL are provider or the upgrader, eg., tie 
15 database administrators must be able to upgrade all types of the installations in an 
enterprise, including connected clients, remote clients, regional servers and 
application servers. 

It is a still further object of our invention to provide support for the upgrading of third 
party software. 

20 It is still a further object of our invention to support both full and partial upgrades 
installed software in an enterprise. 

An additional object is restartability. This means that the upgrade software must track 
the progress of upgrades and automatically roll back changes when an error occurs, 
and the upgrade software must also be able to restart the upgrade from the last save 
25 point 

An important object of the inventiari, especially in an enterprise characterized by 
heterogeneity and/or geopaphical dispersion is centralized definition and monitoring, 
upgrader, e.g., the database adrnimstrators must be able to easily define and distribute 

2. 
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software and schema upgrades from a central location and to monitor the progress of 
upgrades across all installations. 

The upgrade must be able to stand alone. This means that upgrades must be able to 
run by themselves, and not depend on other programs or data. 

5 Finally, these objects must be attained and maintained while preserving ease of use 
and user friendlin.es s. 

SUMMARY OF THE INVENTION 

These and other objects are obtained by the method, apparatus, system, and program 
product of our invention. 

10 Our invention provides software version upgrades and database schema 
synchronization The software provider or upgrader, e.g., the database administrator, 
applies and distributes database schema changes to all remote databases including 
mobile databases and regional databases. Moreover, the software provider or 
upgrader, e.g., the database administrator, applies minor schema changes (e.g. 

15 database extensions), patches and major schema changes without manual mtervention- 

According to our invention, it is possible to provide sol, are version upgrade all types 
of installations. That is, the software provider or the upgrader, e.g, the database 
admfnistrators is now able to upgrade all types of installations and terminals, 
including connected clients, remote clients, regional servers, and application servers. 

20 One aspect of our invention is a method of distributing and instantiating software 
version upgrades in a distributed computing environment. This method includes 
setting the mTrriTmrm (and maximum) levels of the version for installed software, and 
using those levels to define the contents of software version upgrade kits. The 
contents of the software version upgrade kits are then written to a database, e.g., as a 

25 table of contents or the like, and used top generate software version upgrade kit tables. 
These tables are used to build software version upgrade kits. Copies of the upgrade 
kits are downloaded to clients to be upgraded; and the software on the client is 
upgraded. 
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After the table of contents of the software upgrade kits is installed, it is compared to 
the locally installed software on a client, with the Software needing to be installed on 
the client to the client being downloaded to the client This comparison can be at the 
startup of the server, the client, or a particular software component 

5 When the client is a mobile client the comparison and download are carried out at a 
docking session, with instantiation of the upgrade either during the current docking 
session or during a subsequent docking session 

In one exemplification of our invention the distributed computing environment is 
database management system having replicated or partially replicated databases, and 
10 the database schema version on the client is compared to the database schema version 
on server, with reinitialization of the database version on the client if the database 
schema version on the client and the server do not tnatrh, and synchronization of the 
database the client with the database on the server if the database schema versions on 
the client and server match 

15 According to our invention there is support for third party software. The software 
provider or upgrader, e.g., the database administrators is able to upgrade third party 
software that customer installations depend on. For example, the software provider, 
management information services supervisor, or upgrader, e.g., the database 
administrator, is able to upgrade Microsoft Word, Adobe Acrobat, Microsoft Access 

20 and the like residing on customer installations. 

full and partial upgrades. are enabled according to the method and apparatus of our 
invention. Upgrader, e.g., the database administrator, s may upgrade all or part of an 
installation. For example, the upgrader, e.g., the database administrator, is able to 
distribute both a completely new installation and a patch for an existing installation 
25 such as a CDF file, an executable, a DLL, a report, and the like. In a like manner, 
upgrader, e.g., the database administrators is able to distribute upgrades for different 
languages. 

These objects are attained wmle maintaining ease of use and user friendliness. In this 
regard, ease of use requires, automatic detection of existing program and automatic 
30 invocation of upgrade programs, including clients and replication agents. The 
installation software must automatically detect when an upgrade is available and can 
4. 



PAGE 6/50* RCVD AT 8123120055:24:25 PM [Eastern DayOght Time] * SVR:USPTO-E?XRF-6/29 8 DN!S:2738300 * CS!D:2063599000 8 DURATION (mm^s):11-04 



08/23/2005 14:26 FAX 2063599000 



PERKINS CO IE SEAFAJ 



be applied to the local installation, such that the user does not need to explicitly find 
and choose upgrades. User-friendliness requires that software upgrade programs must 
let the user cancel or defer upgrades. The software upgrade programs must keep the 
user informed on the status of upgrades, inform the user of pending upgrades, the user 
5 steps to be performed in an upgrade, time estimates for the upgrade, and progress 
indicators during the upgrades. This includes self upgrading, upgrades must be able 
to upgrade themselves., and upgrader, e.g., the database administrator, s most be able 
to distribute upgrades for the upgrade programs. User-friendliness also includes a 
requirement adaptivity. That is, the ability for individual users to use any method to 
10 install or update software components, whether using an upgrade wizard or not 
upgrades should use current state of the software components to identify whether an 
upgrade is needed, 

A related requirement is res tart ability. That means that the upgrade software must 
track the progress of upgrades and automatically roll back changes when an error 
1 5 occurs, and the upgrade software must also be able to restart the upgrade from the last 
save point 

A desirable property is the availability of early downloads. By this expedient, mobile 
users can download and apply upgrade kits to their local maghinre even before the 
upgrade is required. This lets mobile users download the upgrade when they have 
20 more time or have access to a fast network (e. g visiting HQ). 

A further desirable property is centralized definition and monitoring, upgrader, e.g, 
the database administrators must be able to easily define and distribute software and 
schema upgrades from a central location. Moreover, upgrader, e.g., the database 
a dm i nis trator, s must be able to monitor the progress of upgrades across all 
25 installations. For example, the upgrader, e.g., the database administrator, must be 
able to find all installations that have applied an upgrade. This includes guaranteed 
delivery. AH upgrades are distributed and applied to all installations The upgrader, 
e.g., the database administrator, must not have to explicitly monitor the status of 
upgrades on every installarion- 

30 Our invention provides be support far Test and Production environments, upgrader, 
e.g., the database administrator, s must be able to configure and test upgrades in a test 
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environment, and thereafter, easily migrate the changes to a production environment 
for distribution to all production users. 

The upgrades applied by our invention are able to stand alone. This means that 
upgrade are able to run by themselves, and do not depend on other programs or data. 

5 Installation of upgrades according to our invention requires minimal network traffic 
It is important to minimize file transfers by sending upgrades to only the sites that 
need them. For example, application server upgrades are only sent to regional data 
installations. Microsoft Word upgrades are only sent to client installations. 

THE FIGURES 

10 Our invention may be understood by reference to the FIGURES and TABLES 
appended hereto. 

FIGURE 1 illustrates the process of defining software upgrades. As shown in the 
FIGURE, the administrator defines the upgrade kits, thereby generating upgrade kit 
files. Next, the client writes the upgrade kit demiirion to the server database resident 
15 in the database server, generating further upgrade kit files. The client also copies 
upgrade kit files to the tile server. When the upgrade kit files are to be released, 
upgrade kit archive files are created. 

FIGURE 2 illustrates initiation and distribution of upgrades. In the process shown in 
FIGURE 2 the administrator updates the required versions for a software item This 

20 causes the database server, when started up, this causes the client to compare the 
required versions of the software with the locally installed versions for each software 
item If an upgrade is required the client retrieves the upgrade kit archive file from 
the file server and invokes the upgrade wizard to apply the upgrade locally. Also 
shown in FIGURE 2 is upgrading of mobile users. In the case of mobile users an 

25 application server routes new required versions to mobile and regional users. After a 
docking session, the docking client compares the required versions to locally installed 
versions of the software. If an upgrade is required, the docking client retrieves the 
upgrade kit archive file from the file server and invokes the upgrade wizard to apply 
the upgrade the local machine. 
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FIGURE 3 illustrates the upgrade procedures for customers. As shown in FIGURE 
upgrade distribution CD's or diskettes are created and shipped to customers. The 
customer upgrades a test environment, distributes new version of the software testing, 
and tests the software. If the test is satisfactory, the customer upgrades the new 
5 version to production users. 

FIGURE 4 is a data model for a remote upgrade. It shows the upgrade kit, a kit 
component, including a component, and a related component, a kit item and kit item 
argument, and a kit item type argument 

TABLE I shows an enumeration of the valid actions for the upgrade kit items, such as 
10 copying files into directories, deleting files from directories, invoking stand-alone 
executables, running statements in SQL files, loading data, issuing ddL and loading 
repository files. 

DETAILED DESCRIPTION OF THE INVENTION 

Implementation Overview 

15 The definition of upgrades, the initiation and distribution of upgrades, and end-user 
level upgrading are illustrated in the FIGURES. 

As shown in FIGURE 1, the administrator, shown as the client (101) defines the 
upgrade kits. The client (101) writes this upgrade kit definition to a server database 
(103) resident in the database server, generating upgrade kit tables (104) in the server 
20 database (103). The step of defining the upgrade at the client (101) also generates 
upgrade kit files (1 02. The client copies these upgrade kit files (1 02) to the file server 
(105), for example, for subsequent downloading. When the upgrade kit files (106) are 
to be released, upgrade kit archive files are created 

FIGURE 2 illustrates initiation and distribution of upgrades. In the process shown 
25 FIGURE 2 the administrator (101) updates the required versions for a software item. 

This causes the database server (103), with resident software component tables 
(104A), when started up, to compare the required versions of the software with the 
locally installed versions for each for each connected local user (211) for each 
software item. If an upgrade is required the local user (21 1) retrieves the upgrade kit 

7. 
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archive file (106) from the file server (105) and invokes an upgrade wizard to apply 
die upgrade locally. 

Also shown in FIGURE 2 is upgrading of mobile users (215). In the case of mobile 
users (215) an application server (213) routes new required versions to mobile (215) 
5 and regional users. After a docking session, the docking client compares the required 
versions to locally installed versions of the software. If an. upgrade is required, the 
docking client retrieves the upgrade kit archive file (106) from the file server (105) 
and invokes the upgrade wizard to apply the upgrade to the local machine (215). 

FIGURE 3 illustrates one set of test and distribution procedures for customers. As 
10 shown in FIGURE 3, upgrade CD's or diskettes (307) are created in a master 
repository (305) and shipped to a test database server (303) for distribution to test 
users, including server test users (313), connected test users (311), and mobile test 
users (315). The test users (311, 313, and 315) upgrade their test environments, and 
the upgraded version of the software for testing. The customers (311, 313, 315) test 
15 the software. If the test is satisfactory, the newly upgraded version of the software is 
distributed to production users (4121, 413,415). 

FIGURE 4 illustrates a data model foT a remote upgrade. It shows the upgrade kit 
(1001), a kit component (1003), including a component (1O05), and a related 
component (1007), a kit item (1009) and kit item argument (1011), and a kit item type 
20 (1013). 

Software Components 

The basic unit of upgrades is the software component A software component is a set 
software that can be separately installed and tracked by upgrades. Each software 
component has a range of required versions. The software vendor, the MIS 
25 supervisor, or the upgrader, e.g., the database administrator, specifies the range of 
required for each software component Examples of software components in, by way 
of exemplification only and not limitation, the Siebel Remote application are the 
Siebel Schema, the Siebet Client, the Siebel Server and Microsoft Word 

Upgrade Kits 
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The software vendor, MIS supervisor, or upgrader, e.g., the database administrator, 
creates upgrade kits to install or upgrade one or more software components. An 
upgrade kit is a collection of files and actions to upgrade one or more software 
components from one version to another (usually higher) version. To initiate an 
5 upgrade of a software component, the upgrader, for example, the upgrader, e.g., the 
database administrator, builds and releases an upgrade kit to install the new version of 
the software component Then the upgrader, e.g., the database administrator, updates 
the software component's required versions to ensure that users upgrade to the new 
required version of the software component 

1 0 Automatic Upgrade Detection 

At certain pre-defined times (e.g. client startup, before and after each synchronization 
session, before invoking a third party software component, when the Server starts up), 
system programs verify that software components for the currently running program 
are up-to-date. For example, in the case of Siebel Remote, the Siebel Client checks 
15 the versions of the Siebel Schema and Siebel Client components, but does not 
necessarily check the Siebel Server component The server determines the currently 
installed version of a software component by interrogating the software component 
itself and comparing the installed versions against the required versions. 

If any software component is not within the range of required versions, the server 
20 checks the versions of all software components and searches for one or more upgrade 
kits upgrade the out-of-date software components to the required versions. The server 
then informs the user of the required upgrades and prompts the user to perform the 
upgrade. 

Upgrade wizard 

25 The server invokes an upgrade wizard to apply an upgrade kit. After invoking the 
upgrade wizard, the program exits so as to release any locks on database tables or files 
that need to be upgraded. For example, the client invokes the upgrade wizard and 
exits. The Server sends a shutdown messages to all currently active server 
components, waits for all server components to stop, invokes the upgrade wizard and 

30 exits. 

9. 
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The upgrade wizard is preferably a standalone single executable (no DLLs required) 
that can read and apply an upgrade kit to the local machine. The upgrade wizard 
keeps track of the upgrade's progress and automatically recovers from errors. For 
example, it creates a back up of the local database and local files while applying an 
5 upgrade kit. If an error occurs anytime during the upgrade, the upgrade wizard 
attempts to rollback all the changes and restores the local machine to the original 
state. 

When the Client or Server starts, it detects whether an upgrade is in progress or has 
feiled If so, it informs the user and invokes the upgrade wizard to restart the upgrade^ 
1 0 For the Client, if the user declines to restart the upgrade, the Client continues m read- 
only mode. In read-only mode, the client lets the user view data but prevents the user 
from modifying data. For the Server, if the up grader, e.&, the database administrator, 
declines to restart the upgrade, the Server issues an error message and stops. 

After successfully completing an upgrade, the software components on the local 
1 5 machine should b e up-to-date. The upgrade wizard restarts the original program that 
invoked the upgrade. 

Using Upgrades 

This section describes the process for defining, distributing and applying an upgrade 
more detail 

20 Customize 

The upgrader, e.g., the database administrator, uses tool programs and other programs 
to customize the database management system for their environment The upgrader, 
e_g., the database administrator, has the capability to extend the database schema and 
customize client screens, report files and other files. 

25 Define Upgrades 

The Upgrader, e.g., the database administrator, defines the upgrade in the server 
database. This process consists of defining the software components and the upgrade 
kits needed to upgrade each software component to a specific version. 

10. 
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Define Software Components 

The upgrader, e.g., the database administrator, uses a Software Component screen or 
tool to define new software components. A software component is a set of software 
that can be separately installed, tracked and de-installed by upgrades. As used herein, 
a software component has the following attributes: 

Name. A name to identify the software component 

Required Versions. A range of versions, that is, the minimum and maximum 
versions, that must be installed on each machine. 

Locate Method. A specification of how to detect whether the software 
component is installed on a machine. For example, read the windows registry 
to identify where Microsoft Windows is installed on the local machine. 

Version Method. A specification of how to identify the current version of 
installed software component on a machine. For example, read the Windows 
registry to get the currently installed version of Microsoft Word on the local 



"Compiled" component information. Information about the previously 
released version, of the software component For example SiebeJ Remote 
stores exactly two versions of software components. The user can view and 
manipulate the current version. Siebel Remote stores the previously released 
20 version in a LONG column in the software component table (i.e. 

S_UPO_COMP). The upgrader, e g, the database administrator, uses the 
Component screen to copy the current version into the "compiled" LONG 
column. 

Schema The schema is the database schema, also referred to as a meta- 
25 database. This includes the database tables, indexes, views, seed data and 

repository data that must be installed in the database to run. 

Client The executables, dlls, reports, help files needed to run the client 

CDF. The definition of a customer's configuration for the client 

ii- 
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Server. The executables, dlls and other files needed to run the server. 

Upgrade wizard. The standalone executable that applies upgrade kits on 
machine. 

For most end users, the predefined set of software components described above 
5 complete. If needed, the upgrader, eg., the database administrator, can also define 
one software components that they want to distribute and apply to their users. 

Define Upgrade Kits using the Upgrade Kit screen 

In a preferred embodiment of our invention, the up grader, e.g., the data administrator, 
uses an Upgrade Kit screen to define an upgrade kit to install one or more software 
1 0 components. 

Each upgrade kit must contain all the files and commands needed to install the 
software components. For example, an upgrade kit can be nsed to install Microsoft 
Word 7.0.2 on all clients. This upgrade kit must contain all the files (e.g. executables, 
sample files, templates, etc.) and commands (e.g. update the registry, build short cuts, 
15 etc.) to install Microsoft Word 7.0.2. The upgrader, e.g., the database administrator, 
provides the following Mormation when defining an upgrade kit: 

Upgrade kit information. Provide a name, a title and a description of the upgrade kit 

Upgrade kit items. The upgrader, eg, the database administrator, defines a 
set of actions (or "items") that the upgrade wizard runs in sequence to apply 
20 the upgrade kit Error! Reference source not found, shows a list of possible 

upgrade kit items. The upgrader, eg., the database administrator, pre creates 
the files for the upgrade kit and registers them with the upgrade kit 

Required component versions. The upgrader, e.g., the database administrator, 
also defines the list of required software components that must be installed to 
25 apply the upgrade kit For example, an upgrade kit to import data into the 

database might require that SQL Anywhere v5.5 be installed. 
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Component versions to install The upgrades, e.g., the database administrator, 
also defines the list of software components that the upgrade kit appKes. 
example, an upgrade kit to execute a file might install Microsoft Word 7.0.2. 

The Upgrade Kit screen provides a wizard to help creating upgrade kits at 
5 customer sites. The Upgrade Kit Wizard lets upgrader, eg., the database 

administrator, create upgrade kits for software components that users can 
customize- 
After the upgrader, e.g., the database administrator, finishes defining an upgrade, he 
or she saves the result, for example, by issuing a command, for example, pressing the 
10 "Release" button on the Siebel Upgrade Kit screen, to make the upgrade kit available 
to all installations. The command, for example, the button, does the following: 

Generates an upgrade wizard driver file for the upgrade kit 

Creates an upgrade kit archive file and stores it m the file system. The archive 
file consists of the upgrade wizard driver file and all the fUes needed to apply 
15 the upgrade kit to a machine. 

Compiles the upgrade kit information into a "compiled" LONG column. This 
"compiled" column stores all the information needed by programs to find the 
upgrade kits. This "compiled" column is provided to reduce the time to find 
upgrade kits. 

20 Deploy Upgrades 

After de fini n g the upgrade, the upgrader, e.g., the database administrator, then 
initiates the upgrade from the server database. Client programs at all locations 
automatically detect and apply the upgrades as needed 

Early Download of Upgrade Kits 

25 After the upgrade kit is defined, it is possible to distribute the upgrade kit definitions 
associated files to mobile and regional databases. In this case mobile users can 
navigate to the Upgrade Kit screen and request that the database management system 
download the upgrade kit archive file in the next synchronization session. This lets 

13. 
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mobile users download large upgrade kit archive files long before the upgrade kit 
needs to be applied to tie local machine. For example, the mobile user may be 
visiting headquarters and can download the upgrade kit archive file in much less time 
over the LAN than over a modem. 

5 Early download of upgrade kits is not mandatory for mobile users. The mobile user 
does not need to explicitly request the upgrade kit archive rile: The database 
mana gement software can automatically download the upgrade kit archive file if it 
needs to apply the upgrade kit and the upgrade kit archive file is not accessible on the 
local machine. 

10 Initiate Upgrades 

After defining software components and upgrade kits, the upgrader, e g., the database 
administrator, can initiate an upgrade of the software component. The upgrader, e.g, 
the database administrator, must first set the required versions of the software 
component. There are two ways of setting the required versions: The first way is 
15 through the component screen. The upgrader, e.g., the database administrator, uses 
the component screen to manually update the required versions for a software 
component He or she uses the screen to modify the minimum or man-mnim required 
version of one or more software components. 

Alternatively, the upgrader, e.g., the database administrator, can utilize an Upgrade 
20 Kit screen. The upgrader, e.g., the database administrator, uses the Upgrade Kit 
screen update the required versions of a software component The upgrader, e.g., the 
database administrator, selects an upgrade kit, and, initiates a function to set the 
required versions for example, in the case of Siebel Remote, the upgrader presses the 
"Set Required Versions" button. The button finds all the software components that 
25 the upgrade affects and sets their tnayfrrmTn versions. The maximum versions are set 
to the versions that the upgrade kit installs. 

The upgrader, e.g., the database administrator, uses a component or similar screen to 
"release" the new software component information to all users. The upgrader, eg., 
the database administrator, selects a software component and presses the "Release" 
30 button. The button reads all the information about the selected software component 
and related software components, verifies the iruTormation, writes the information to 
14. 
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the "compiled" LONG column and togs a transaction to replicate the information to 
all databases. 

Detect and Apply Upgrade Kits 

Upgrade programs of our invention automatically detect an upgrade by comparing the 
5 currently installed version of each component to the required versions. The client 
reads the required versions from the software component "compiled" LONG column 
at start up. Servers also read the required versions from the software component 
"compiled" LONG column at start up. 

For mobile users and regional databases, the upgrader, e.g., the database 
10 administrator, distributes the updated required versions to all remote databases. The 
docking client and Replication Agent query the docking server for the required 
schema versions before each synchronization session. If a change to the software 
component compiled column occurs during a synchronization session, the docking 
client and Replication Agent reads the required versions after the synchronization 
15 session. 

If any of the versions do not match, then an upgrade is required and the program 
searches for one or more upgrade kits to apply, applies the upgrade kits in two steps: 

Download the upgrade kit archive file to the local machine 

Invoke the upgrade wizard to apply the upgrade kit to the local machine 

20 For mobile and regional database installations, the docking client downloads the 
upgrade kit archive rile from the server, typically the database server, to the local 
inbox directory. For connected users, the client downloads the upgrade kit archive 
file in the file system to the temp directory on the local disk. 

After the upgrade kit is accessible on the local machine, the upgrade wizard applies 
25 the upgrade. The upgrade wizard extracts files from the upgrade kit archive file, then 
performs each of the upgrade kit actions in sequence. If an error occurs, the upgrade 
wizard rolls back the upgrade kit actions and displays an error to the user. The 
program detects and invokes upgrades again the next time. 
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After successfully completing all the upgrade kit actions, the upgrade wizard deletes 
the upgrade kit files from the local machine and restarts the program that invoked the 
upgrade. 

Integration 

5 The upgrade installation system uses a package, for example, Siebel Upgrades, to 
initializ e and main tain remote databases. The upgrade wizard initializes new remote 
databases, performs database re-extracts, and handles database schema upgrades. 

Extract Remote Databases - When extracting a remote database, Database Extract 
creates an upgrade kit archive file in the outbox directory. This database extract 
10 archive file consists of an upgrade wizard driver file and several items to initialize the 
local database: 

Create database. Copy me database template file (for mobile users) 

Snapshot data. Import a database snapshot file containing visible data for the mobile 
user 

15 Sql files. Execute a set of SQL files that create users and initialize data in the 
database. 

Database Initialization 

The client, Replication Agent, docking client and standalone Dbinit (database 
initialization) program invoke Dbinit to initialize a local database. Database 
20 initialization (Dbinit) ensures that all required versions exist on the local machine and 
creates a local database for the mobile client 

Dbinit performs these steps: 

Connect to Server. Dbinit pr o mp ts the user for the name of the local mobile 
client, the password for the mobile client and the address of the Remote Server 
25 (the mobile user should get mis information from his or her upgrader, eg., the 

MIS staff, the vendor, or the database administrator,). Database initialization 
connects to the Remote server and validates the mobile client name, user and 
password. 

16. 
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Perform version check and download upgrade kits. Dbinit then performs a 
version check to ensure that all required software components exist on the 
local machine. Dbinit first downloads the required versions (ie. the compiled 
information) from the docking server. Dbinit compares the required versions 
5 against the versions on the local machine. If one or more versions do not 

•match, then Dbinit downloads information about all (all? Not some?) upgrade 
kits. Dbinit then searches for upgrade kits to apply and downloads the 
upgrades kits to the local inbox directory. 

Download extract snapshot file. Dbinit downloads the database extract 
10 snapshot file to the local mbox directory. 

Create driver file. Dbinit creates an upgrade wizard driver file to apply the 
upgrade kits to the local machine and create the local database using the 
database extract snapshot file. 

Run upgrade wizard. Dbinit invokes the upgrade wizard to apply the upgrade 
1 S kits and initialize the local database. 

If the initialization is successful, the upgrade wizard then restarts the calling pro gram. 

Automatic Initialization from the client 

When a mobile user runs the client against the local database, the client checks 
whether the local database file exists. If the local database does not exist, the client 
20 prompts the user whether he wants to initialize a local database. If so, the Client 
invokes Dbinit to create the local database and also ensure that all software 
components are up-to-date. 

Version Checking 

At the beginning of each synchronization session, the docking client checks whether a 
25 database extract or a database schema upgrade is pending. This is because the 
docking chent must perform a schema version check at the start of the docking 
session because the docking client must know whether it can upload transactions to 
the server database or must discard the transactions. The docking client also must 
know whether it must perform a dbinit to re-initialize the local database. 

17- 
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After the docking client connects to die docking server, the docking client asks 
docking server for the server database schema versions. There are three possible 
outcomes: 

Major Schema Change. If the major and minor schema versions of the local database 
5 and the server database do not match, then a database re-initialization is "required". 
A change in the major or minor schema versions implies that the server database has 
undergone a major schema change. The docking client discards all pending 
transactions to upload. The docking client informs the mobile user and invokes the 
upgrade wizard to initialize the local database and upgrade sol, ware components (if 

1 0 any). If a database extract is not available, then the docking client displays an error 
asking the mobile user to contact the up grader, eg., the database adrrunistrator, to Te- 
extract the docking client Pending Dbinit, if there is no major schema change and 
the upgrader, e.g.„ the database ad^mnistratoT, has re-extracted the docking client, then 
the docking client must re-initialize the local database. The docking client saves all 

15 pending transactions to upload in a file in the inbox directory called dbinit. dx. The 
docking client invokes the upgrade wizard to create the new local database and 
upgrade any new software components. After initializing the local database, the 
upgrade wizard invokes the data merge utility (dmutlexe) to apply the saved pending 
transactions in dbimtdx to the local database. DmutLexe applies the transactions to 

20 the local database and logs new transactions to upload to the server database, as if the 
mobile user has re-entered all the transactions. 

Minor Schema Change. If there is no major schema change and no pending dbirrit, 
then the docking client proceeds to synchronize the docking client. Eventually, the 
docking client applies a transaction to upgrade the required versions of the Schema 
25 sol, are component This update triggers the docking client to perform a version 
check and eventually causes the upgrade wizard 
apply an upgrade kit to upgrade the local database. 

Initialize a Regional Database 

The upgrader, e.g., the database administrator, on the regional database runs 
30 standalone database initialization program to initialize a regional database. The 
program connects to the Remote server and downloads the database extract archive 

18. 
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file from oufcox directory. The program then invokes the upgrade wizard to initialize 
the regional database. 

Replace a Regional Database 

If the upgrader, e.g., the database administrator, on the HQ server runs database 
5 extract for an existing regional database, the upgrader, e.g, the database 
administrator, on the regional database needs to re-initialize the regional database. At 
the beginning of the each synchronization session, a Replication Agent checks 
whether a database extract archive file is pending for the regional database. If so, the 
Replication Agent notifies the upgrader, e.g., the database administrator, and shuts 
10 down. The upgrader, e.g., the database administrator, must manually invoke the 
standalone database initialization program to initialize a regional database. 

The Schema upgrade kit consists of one or more of the following items: 

DDL file to make schema changes 

DAT files to install seed data 

15 Repimexp files to install Repository 

SQL scripts to perform special upgrade steps, convert data, and the like 

SQL script to update version numbers in the S_APP_VER table 

Files to update software components. This includes adding, deleting and 
updating software component information. At the minimum, the file mnst 
20 update required versions of the components (e.g. you must use the new version 

of Tools against the new schema). 

Files to install upgrade kits mat defines. For example, upgrade kits to install a 
new version of Tools, Server and the like. 

Installing the Schema at Customer Sites 

25 The upgrader, e.g., the database administrator, receives the CD, or other media, and 
applies the upgrade kit to the test/configuration database Before applying the 
vmgrade kit, the upgrader, e.g., the database administrator, first shuts down all 
19. 
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programs: both connected users and Servo- instances. Then he or she runs the 
upgrade wizard to apply the upgrade kit to the test database 

The upgrade kit performs the following steps: 

Makes schema changes 

5 Imports seed data 

Runs repimexp.exe to import the new Repository 

Runs SQL scripts to perform special upgrade steps, convert data, and the like. 
Updates the version numbers. 
Runs files to update the software component tables. 
1 0 Runs riles to install - definedupgrade kits. 

Accessing the Database after an Upgrade 

At this point, the test/configuration database has the new schema and the software 
component required versions are set to the new versions. Any program that connects 
to the server database needs to apply one or more upgrade kits to get to the new 
15 required versions. For example, when the upgrader, e.g., the database administrator, 
logs in to the server database, the software used to login should detect a version 
mismatch and attempt to upgrade or call the upgrade. The upgrader, e.g., the database 
administrator, has two options to upgrade to the new Tools version: If an upgrade kit 
is available, download the upgrade kit and apply it to the local machine. 

20 Install the new version from the CD-ROM. Then, use the version against the server 
database, upgrader, e.g., the database administrator, must use this option if this is the 
first time they installed software on the local machine. 

If the upgrader, e.g, the database administrator, wants to let programs perform 
upgrades, he or she can register upgrade kits to upgrade the various software 
25 components. Otherwise, he or she can manually upgrade each machine by installing 
from the CD-ROM. 
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Customizing and Testing 

Up grader, e.g., the database administrator, can customize local installations in 
these three ways: 

Database extensions such as new extension tables, extension columns or 
5 indexes. Configuration changes such as new CDF files, CFG files or report 

files. 

Third party software changes such as new versions of Microsoft Word, Adobe 
Acrobat and the like. 

Customers follow a well-defined procedure for creating and distributing these kinds 
10 of customization^. All of these customizations do not cause a major schema change; 
hence, they do not require a datab ase re-extract 

Step 1: Make the configuration changes on the server database The upgrader, e.g., the 
database a dmini strator, uses programs to customize end-user installations for then- 
site, and merge the customer's repository with a new repository. 

15 To effect configuration changes during the version or schema upgrade, new .CDF 
files need to be generated. This is done using an editor to customize CFG files. And 
a DBMS program such as Microsoft Access to customize reports. Microsoft Help 
Editor or the tike may be used to customize the Help files 

Programs in the upgrade kit compare versions and automatically detect the need to 
20 apply an upgrade the next time they start up. The method, apparatus, system, and 
program product of our invention upgrades connected users In a similar way, the 
server upgrades application servers, or, when present, a docking client upgrades local 
databases. A Replication agent upgrades regional databases. 

The method, apparatus, system, and program product of our invention downloads the 
25 required upgrade kits and applies the upgrade to the local machine. If the database 
upgrade changed the major or min or schema versions, the upgrade method, system, 
apparatus, and program product of our invention automatically re-initializes the 
mobile or regional database. 



21. 

PAGE 23150 ' RCVDAT 8/23/2005 5:24:25 PM [Eastern Daylight Time] • SVR:USPTO-EFXRF-6i29* DN1S:2738300 ' CSID:2063599000 ' DURATION (mm-ss):1144 



08/23/2005 14:30 FAX 2063599000 PERKINS COIE SEAFAX1 ' 



A further aspect of our invention is the automatic setting of the required versions 
software components. Alternatively, the upgrader, e.g., the database administrator 
can update the required versions and initiate upgrades of one or mere software 
components. In a networked environment the upgrader, e.g., the database 
5 ad minis trator, should be very careful when making changes to listing of required 
versions because updates to this file can cause programs at all locations to invoke 
upgrades 

In most cases, the application server is self-upgrading That is, the upgrader, e.g, the 
database administrator, does not need to intervene to detect and apply an. upgrade. 
1 0 However, there are exceptions. If the upgrade kit requires user intervention, then the 
upgrade software should wait until the upgrader, e-g., the database admimstrator, 
provides input 

Similarly, if a- database extract is pending., for example, for a regional database, the 
server must shutdown all access to the regional database, ensure that the transaction 
1 5 merger has successfully merged all pending .dx files from mobile clients, and initiate 
a database initialization process to re-initialize the regional database. 

The software upgrade programs of the invention automatically detect and apply 
upgrades as needed to maintain the correct software component versions on all 
machines. Users do not need to manually search for and apply upgrades. This is 

20 especially true of users connected on a LAN or "WAN, who experience painless 
upgrades. The client automatically detects and applies upgrades as needed. If an 
upgrade is detected, die client notifies the user of the software components to 
upgrade, encourages the user to apply the upgrade and prompts the user to start the 
upgrade. The system automatically downloads the appropriate upgrade kits to the 

25 local disk if the upgrade kit does not already exist on the local disk. 

After the upgrade kit is available on the local machine, the client invokes the upgrade 
wizard to apply the upgrade. The upgrade wizard displays the upgrade kit items 
prompts the user to start the upgrade. The upgrade wizard starts processing the 
upgrade kit items and regularly informs the user of the progress. When the upgrade 
30 wizard complete, it restarts the original program. 
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Mobile users also experience painless upgrades. Mobile users do not need to 
explicitly invoke database initialization. Attempting to start the Client against the 
local database with no local database available automatically invokes database 
initialization to create the local database. Dbinit also ensures that all software 
5 components are up-to-date on the local machine. 

Mobile users can download upgrade kits earlier than necessary by navigating to the 
Upgrade Kit screen and requesting to download the upgrade kit archive file in the next 
synchronization session. 

The upgrade software of our invention performs a version check at the start of each 
1 0 synchronization session. If an upgrade is detected, the client no titles the user of the 
software components to upgrade, encourages the user to apply the upgrade and 
prompts the user to start the upgrade, automatically downloads the appropriate 
upgrade kits to the local disk if the upgrade kit does not already exist 1 on the local 
disk. 

1 5 After the upgrade kit is available on the local machine, the client invokes the upgrade 
wizard to apply the upgrade. The upgrade wizard displays the upgrade kit items and 
prompts the user to start the upgrade. The upgrade wizard starts processing the 
upgrade kit items and regularly informs the user of the progress. When the upgrade 
wizard is complete, it restarts the original program. 

20 If a re-initialization is required, the docking client invokes Dbinit to reinitialize the 
local database. 

In one exemplification of our invention a component screen lets the up grader, e.g., 
database administrators define software components and specify the required versions 
for software components. This screen also lets upgrader, e.g., the database 
25 administrator, specify dependencies between software components. For examplej the 
client software component requires that the Schema component and the Schema 
component are already installed before the client can start up. 

The component screen has two applets:, a software component applet which defines 
the name and required versions for a software component, and a required software 
30 component applet, which defines the list of other software components required to use 

23. 
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the current software component This applet is a child of the software component 
applet 

The Software Component applet lets the upgrader, e.g., the database administrator, 
enter the attributes of a software component. It can have one or more of the following 
5 fields: 

Name (required). The name of the software component 

Comments (optional). The description of the software component Minimum 
version (optional). The miniraam version that must be installed on a machine 
to use this software component If NULL, then the software component does 
1 0 not have a minimum version 

Maximum version (optional). The maximum version mat must be installed on 
a machine to use the software component If NULL, then the software 
component does not have a maximum version. The applet verifies that the 
rmn i m um version is less than or equal to the maximum version. 

15 Locate method (optional). The method to use to get the install location of the 

software component This is a picklist 

Locate Info (optional). Additional information for the locate method. 

Version method (optional). Method to get the currently installed version of 
software component This is a picklist 

20 Version Info (optional). Additional information for the version method. 

The Software Component applet, lets the npgrader, e.g., the database administrator, 
define required software components for a software component This applet has the 
following fields: 

Required software component (required). The name of the required software 
25 component. 

Comments (optional). 
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Start up flag (required). Specifies whether the required software component is 
required to start up the software component. Some required software 
component are used by a software component but not required for start up. 
For example, the client requires Microsoft Word if the user uses 
5 Correspondence but Microsoft Word is not required when starting up the 

client. Upgrade Kit Item Arguments screen. It is possible to use this screen to 
define (he list of valid arguments for each upgrade kit item type. This screen 
has one applet: 

Upgrade Kit Item Type Arguments applet This applet Jets the upgrader, e.g., the 
10 database administrator, enter the valid arguments for an upgrade kit item type. This 
applet has the following fields: 

Item type (required). The type of upgrade kit item to apply. Error! Reference 
source not found, shows the valid types of upgrade kit items and their 
respective arguments. This is a picklist. 

15 Sequence (required). An integer denoting the sequence that upgrade wizard 

passes the argument to apply the upgrade kit item. 

Required Flag (required). Specifies whether the argument is required 

Comments (optional). The description of the upgrade kit item type argument 

Default value (optional). Default value of the argument 

20 Upgrade Kit applet 

This applet lets the upgrader, e.g. s the database administrator, enter the attributes of an 
upgrade kit This applet has the following fields: 

Name (required). The name of the upgrade kit. 

Title (required). The user-friendly name of the upgrade kit The upgrade 
25 wizard displays this string on the title bar of the upgrade wizard dialog box. 

This value defaults to the name of the upgrade kit 
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Comments (optional). The description of the upgrade kit The upgrade wizard 
displays this description, -when the upgrade wizard starts up. 

Status (required). The current status of the upgrade kit The status is set 
'Pending' when defining the upgrade kit. After the upgrader, e.g., the 
5 database administrator, presses the "Release" button, then the status changes 

to 'Active' The status changes to 'Inactive' if the upgrader, eg., the database 
administrator changes the status chooses the delete record action on the 
upgrade kit. 

Upgrade kit archive file (optional). The attributes for the attached upgrade kit 
10 archive file. These are the attributes used by the file attachment business 

component and frames. Mobile users can navigate to this applet and request 
that Remote download the upgrade kit archive in the next synchronization 
session. 

After the upgrader, eg., the database administrator, "releases" the upgrade kit, any 
mobile or connected user can download and apply the upgrade kit to the local 
machine. The user navigates this applet and double clicks on an upgrade kit If the 
upgrade kit archive file is not accessible on the local machine (ie. mobile user), then 
the applet asks the user whether they want to submit a request to download the 
upgrade kit archive file m the next synchronization session. If the upgrade kit is 
already accessible on the local machine, then the applet invokes the upgrade wizard to 
apply the upgrade kit to the local machine. The upgrade wizard waits for the client to 
exit before starting the upgrade. 

Upgrade Kit Items applet. This applet lets the upgrader, e-g., the database 
administrator, enter the items for the upgrade kit This applet has the following fields: 

25 Sequence (required). An integer denoting the sequence in which to execute 

the upgrade kit items. 

Title (required). The useT-fhendly title of the upgrade kit item. The upgrade 
wizard displays this string on the list of items to perform in the upgrade. 



15 



20 
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Comments (optional). The description of the upgrade kit item. The upgrade 
wizard displays this description when the user highlights the upgrade kit item- 
Disk Space Estimate (optional). The amount of disk space required to apply 
upgrade kit item to a machine. The upgrader, e.g., the database administrator, 
5 provides this estimate. If the estimate is NULL, then the upgrade wizard 

makes a disk space estimate based on same predefined rules. 

Item type (required). The type of upgrade kit item to apply. Error! Reference 
source not found, shows the valid types of upgrade kit items and their 
respective arguments. 

10 The Upgrade Kit Item Arguments applet lets the upgrader, e.g., the database 
adrninistrator, enter arguments for an upgrade kit item. The list of valid arguments foT 
each upgrade kit item type is stored in the S_UPG_ITARG table. This applet creates 
intersection records between upgrade kit items and upgrade kit type arguments. This 
applet has the following fields: 

15 Name (required). The name of the argument 

Comments (optional). The description of the upgrade kit item. The upgrade 
wizard displays this description when the user highlights the upgrade kit item. 

Argument value (required). 

File attributes (optional). The attributes fox files attached to the upgrade kit 
20 argument The upgrader, eg., the database administrator, attaches files to the 

upgrade kit item. 

The Upgrade Kit Components applet lets the upgrader, e.g., the database 
administrator, define which software components are required for tw< upgrade. For 
example, you can not install version 3. 1.2 on arm chine unless you have version 3. 1 .0 
25 or higher already, installed on that particular local machine. This applet also lets the 
upgrader, e-g., database administrators specify the sol, rare components that the 
upgrade kit affects. 

This applet has the following fields: 
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Software Component (required). The software component that is affected by ^ 
this upgrade kit. 

Minimum Installed Version (optional). This field stores the minimum version 
of the software component required to install this upgrade kit This field can 
5 be left NULL if the upgrade kit does not require this software component. 

Maximum Installed Version (optional). This field stores the ma-Hirm™ 
version of the software component required to install this upgrade kit This 
field can be left NULL if the upgrade kit does not require this software 
component. 

10 New Installed Version (optional). This field stores the new version, of the 

software component if this upgrade kit is applied to a machine. This field can 
be left NULL if the upgrade kit does not install a new version of the software 
component. 

The dialog in this applet verifies that the minimum version is less than or equal to the 
\5 maximum version. It also verifies that the new version is greater or equal to the 
maximum version. 

The Upgrade Kit Wizard includes a set of pre-defined dialogs to assist the upgrader, 
e-g., the database aomrnistrator, in creating upgrade kits that customers need most 
often. It may contain one or more of the following elements : 

20 Screen 1: Choose Upgrade Kit Type 

Database extension. Create an upgrade kit to apply the database 
extensions. The upgrade kit consists of two upgrade kit items: a DDL 
file to apply database schema changes and a DAT file to distribute the 
Repository data file to remote databases. The Repository data file 
25 contains a subset of repository tables needed to initialize the dictionary 

common api 

CDF files. Create an upgrade kit to distribute the new CDF files to all 
users. 
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Report files. Create an upgrade kit to distribute the new Report files to 
all users. Help files. Create an upgrade kit to distribute the new Help 
files to all users. 

Sample Database. Create an upgrade kit to distribute the new Sample 
Database to all users. 

Third Party Software. Create an upgrade kit to distribute the third 
party software to all users. 

Screen 2: Pull or Patch Install 

Full install 

Patch install 

Screen 3: Version Information 

Enter minimum required version: Fot rail installs, defaults to NULL. 
Otherwise, defaults to ? 

Enter maximum required version: For full installs, defaults to NULL. 
Otherwise, defaults. 

Enter new version: defaults to software component's current maximum 
version + 1 

The dialog verifies that the rmmmum version is less fhnTi or equal to 
the maximum version. It also verifies that the new version is greater or 
equal to the maximum version. 

Screen 4: Files 

Enter the source files: For full installs, select a directory that contains 
the files for the upgrade kit The Upgrade Kit Wizard adds all the files 
in the directory and sub-directories to the upgrade kit 

For patch installs, select one or moTe files to add to the upgrade kit 
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Enter the destination directory for the files. c 
Screen 5: Confirm 

Review the information for the new upgrade kit and press OK to create 
the new upgrade kit Otherwise, press Cancel to abort 

5 A major component of the system, method, apparatus, and program product of our 
invention is the upgrade wizard The primary function of the upgrade wizard is to 
apply upgrade kits. In a preferred exemplification of our invention the upgrade 
wizard has very simple user interface. When the upgrade wizard first starts up, it 
displays the title and description of the upgrade kit to the user. After the user presses 
10 the OK or other similar button, the upgrade wizard then displays a list of upgrade kit 
items to the user. The upgrade wizard displays the title of the upgrade kit item. 
When the user highlights a specific upgrade kit item, the upgrade wizard also displays 
the description of the chosen item in the bottom frame. 

After the user reviews the upgrade kit items and presses the START ot other similar 
15 button, the upgrade wizard performs each of the upgrade kit items in order. A bar 
indicator may show an estimate of the progress of the upgrade. The upgrade wizard 
may also highlight the upgrade kit item after the item is completed. 

Algorithms and Procedures 

Version Checking Function. To check a software component's version, the upgrade 
20 wizard gets the required versions from the database and the actual versions from the 
software component itself. To determine which components need checking, the 
upgrade wizard starts from the base component and walks through the required 
component network to get a list of the required components. 

The upgrade wizard programs call a function to do the version checking. The caller 
25 passes the "compiled" component information. The function returns a list of software 
components that are out-of-date and the current and required versions foT each out-of- 
date software component 

The function must check the version for each software component listed in the 
"compiled" component information. First, the function must locate the component. 

30. 
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this regard, "Error! Reference source not found" shows a list of methods for locating 
software components. Once located, the function can check the version of the 
component and the function can determine if the component can be upgraded The 
CDF file stores a version number in the CDF file. The Upgrade Kit Wizard writes the 
value to the CDF file. 

The CFG files: add a new version attribute in [] section. The Upgrade Kit Wizard 
writes the value to the CFG file. 

Determining Which Upgrade to Run. The upgrade kit component table stores 
component and version information for an upgrade kit. This table describes which 
components an upgrade kit installs and which components are required by the 
upgrade. Detecting which upgrade kits to apply may be non-trivial. 

The method, apparatus, system, and program product of our invention uses a recursive 
algorithm to search for the necessary upgrade kits. The algorithm is as follows: 

If current_versions=desired_versions 

Call callback with current upgrade hst 
Return TRUE; 

If upgrade list is full 
Return TRUE; 

For each upgrade 
Do 

If upgrade already in upgrade list 
Continue; 

If upgrade can't be run now (i.& 
upgrade_required_vereions != current-versions) 

Continue; 

Add upgrade to the list 

Apply upgrade information to current_versions 



Remove upgrade from the list 

Remove upgrade information from current_versions 

Done 

Return TRUE; 

This algorithm produces a list of upgrade kit to get from the current installed version 
to the required version. If there is more than one path, the function selects the path 
with the fewest upgrade kits. 
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Upgrade wizard. The upgrade wizard is a simple, standalone program whose sole 
function is to apply upgrade kits to a local machine. The upgrade wizard does not 
connect to or require the Database to run. The upgrade wizard reads all parameters 
and stores state information in simple files. The upgrade wizard need not be capable 
5 of merging transactions. The upgrade wizard can perform the implementation portion 
of Dbinit (though not the transfer portion). 

Running the upgrade wizard. The upgrade wizard reads two types of files: a state file 
and an upgrade driver file. Both file types are human readable so support can "fix" 
the files if needed. 

10 State file. The state file contains a hst of upgrades 'that need to be run and the 

state of the upgrade. The state file is empty if there are no upgrades pending 
or in-progress. The client and Server programs check the state file during 
start-up. If the state file is not empty, they invoke the upgrade wizard to 
resume the upgrade. 

15 Driver file. The upgrade driver contains a list of upgrade kit items that need to 

be performed for the upgrade. Error! Reference source not found, shows a list 
of valid upgrade kit items. 

At start up, the upgrade wizard reads the driver file and verifies that there is sufficient 
disk space to apply the upgrade. The upgrade wizard uses the disk space estimate 
20 supplied for each upgrade kit item. If the upgrader, e.g., the database administrator, 
not provide an estimate, the upgrade wizard estimates the disk space using some Dun 
algorithm The upgrade wizard notifies the user if there is insufficient disk space on 
local machine to apply the upgrade kits. 

The upgrade wizard then reads the state file. If the state file is not empty, the upgrade 
25 wizard first rolls back all changes by rurming the completed upgrade kit items in 
reverse order. 

The upgrade wizard estimates the time to apply the upgrade kits to the local machine 
and waits for the user to start the upgrade. The upgrade wizard updates the status file 
as it processes actions. It flushes the changes to disk (using ffush, and _commit). 
30 The upgrade wizard saves data to a backup directory before performing each action. 
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Xxx shows the backup steps it takes for each upgrade kit items type. For example? 
prior to executing any database related actions, the upgrade wizard backs up the local 
database. We don't actually believe this will improve recoverability, but it can't hurt 
(well, it can actually). When the upgrade completes successfully, the upgrade wizard 
5 deletes all backup files. It also deletes the upgrade status file is deleted 

Upgrading the upgrade wizard The upgrade -wizard has no dependencies on any 
other program. It does not load CFG files or DLLs. To support upgrading the 
upgrade wizard itself, programs that invoke the upgrade wizard follows these steps: 

Check if a "ready" version of the upgrade wizard executable exists. 

10 If a "ready" version exists, delete the existing upgrade wizard 

executable and rename the "ready" version to current upgrade wizard 
executable. 

If a upgrade wizard executable does not exist, rename the source 
upgrade wizard to the upgrade wizard executab le. 

15 The upgrade wizard Tenames the source upgrade wizard to the ready 

upgrade wizard when it finishes an upgrade. Preferably this happens 
when the upgrade status file is empty which wfll let the user change the 
format of the status file. Alternatively, this can be done immediately 
after an upgrade which has produced an upgraded upgrade wizard 

20 executable so that the next upgrade can take advantage of new upgrade 

wizard features and presumably new upgrade wizard driver file syntax. 

This algorithm ensures that the same upgrade wizard is be used throughout the 
upgrade, even if it is restarted after installing a new version of the upgrade wizard. 

Invoking the Version Checking Function Each program calls the version checking 
25 function at pre-defined times. 

Client 
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At startup, perform a versiot) check for client The client reads the 
required versions from the S_UPG_COMP table's "compiled" LONG 
column and passes the information to the version checking function: 

Server 

5 At startup, the Server starts a new server component - Server Version 

Checker-to perform the version check. The Server Version Checker 
reads the required versions for the Server component from the 
S_UPG_COMP table's compiled" LONG column and passes the 
information to the version checking function. 

10 Docking Client and Replication Agent 

At the start of each synchronization session, the docking client (or 
replication agent) gets the schema version of the server database via a 
DRL message. The docking server reads the server database 
S_APP_VER table and sends the server database schema version to the 
15 docking client If the major schema version on the server database and 

local database are different or a dbinit is pending, then the docking 
client invokes Dbinit to reinitialize the database. 

Data Merge -watches for transactions that update the "compiled" 
LONG column in S_UPG_COMP. For the docking client, Data Merge 
20 watches foT changes to the" Client" component For the Replication 

Agent, Data Merge watches for changes to the" Server" component. 

As soon as Data Merge applies a transaction on this column for the "watched" 
component, Data Merge commits and stops merging transactions. The 
docking client then performs a version check. The Replication Agent starts 
25 the Server Version Checker to perform the version checks. If one or more 

required versions do not match, then the docking client (or Server Version 
Checker) finds one or more upgrade kits to apply, downloads the upgrade kit 
archive files (if not already accessible on the local disk) and invokes the 
upgrade wizard to apply the upgrade. 
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Dictionary Cache File. The dictionary cache file (ie. the subset of the Repository 
needed by server programs and the docking client) provides a "cache" file which 
programmed to load the dictionary into memory. Using a "cache" file eliminates the 
need to load the dictionary data into all remote databases reduces the size of the rem( 
5 databases and also reduces the time to initialize or upgrade remote databases. It is 
possible, and is within the scope of our invention, to use the existing diccache-dat 
mechanism for the "cache" file. The diccachcdat file contains a file representation G 
dictionary. In operation, a version number is stored in the diccache-dat file to identify 
its version and add new methods for reading the version number from the diccachcdat 
10 file is typically in the <_ROOT>\bin directory. 

While our invention has been describ ed with respect to certain preferred embodiments 
and exemplifications, it is not intended to limit the scope of the invention thereby. 
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